package com.example.warehouse.sys.dao.persist.respository;

import com.example.warehouse.common.pojo.vo.PageData;
import com.example.warehouse.sys.pojo.entity.SysRole;
import com.example.warehouse.sys.pojo.entity.SysUser;
import com.example.warehouse.sys.pojo.vo.SysRoleListItemVO;

import java.util.List;


public interface IRoleRepository {

    /**
     * 插入新角色
     *
     * @param role 角色
     * @return int
     */
    int insert(SysRole role);

    //根据id删除
    int deleteById(Long id);

    //根据id修改
    int updateById(SysRole role);

    //根据用户名查询数量
    int countByName(String name);

    int countByNotIdAndName(Long id,String name);
    //根据id查询数量
    int countById(Long id);

    /**
     * 根据id查询
     * @param id 查询id
     * @return
     */
    SysRoleListItemVO roleById(Long id);

    /**
     * 根据name查询
     * @param name
     * @return
     */
    SysRoleListItemVO roleByName(String name);

    /**
     * 查询角色列表
     *
     * @return 角色列表
     */
    List<SysRoleListItemVO> list();


    PageData<SysRoleListItemVO> list(Integer pageNum, Integer pageSize);

    /**
     * 查询所有数据
     *
     */
    List<SysRole> selectAll();
}
